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© Microcircuit pour carte a puce multi - applica - 
tions comportant notamment une memoire ROM 
(12), une memoire programmable (13) et un circuit 
de controle d f adressage (14) de cette memoire 
programmable. 

Selon I'invention, la memoire programmable (13) 
est partagee en au moins une zone de repertoire 
(ZR) et une zone des applications (ZA), la zone de 
repertoire (ZR) comportant par application chargee, 
au moins un code de reference d'une application i 
presente dans la zone ZAj ainsi que les adresses 
ZAh et ZA ih respectivement de debut et de fin de la 
zone ZAj allouee a cette application. 

Le microcircuit comporte egalement des moyens 
(25 a 50) pour inhiber toute commande (R, W ou E) 
de la memoire programmable (13) lorsqu'elle est 
relative a une adresse exterteure a I'intervalle ZA^ - 
ZA ih de Tapplication en cours de traitement et sauf 
s'il s'agit d'une operation prioritaire specifiquement 
prevue par un programme fixe dans la memoire 
ROM (12). 

Application : carte a microcircuits. 
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La presente invention concerne un microcircuit 
pour carte a puce comprenant entre-autres : des 
moyens d'acces entree - sortie, au moins une 
memoire qui est programmable et accessible par 
un espace d'adressage a adresses consecutives, 
un circuit de controle d'adressage de cette me- 
moire programmable determinant soit une inhibi - 
tion, soit une validation des commandes d'ecriture 
et/ou de lecture par la comparaison de Tadresse 
demandee avec deux valeurs limites de debut et 
de fin d'une zone particuli^re d'adresses, limites 
qui sont memorises au sein du circuit de controle 
d'adressage lequel circuit comporte egalement une 
voie d'autorisation prioritaire permettant de s'af- 
franchir temporairement de ladite inhibition dans 
des circonstances predetermines et particulieres. 

Un tel microcircuit est notamment connu du 
document FR 2 304 989. 

L'application dans ie domaine bancaire des 
cartes portatives au sein desquelles est incorpore 
un circuit integre electronique (encore appele 
"puce") est bien connue ainsi que la grande se- 
curite de fonctionnement qui en resulte. II est en 
effet pratiquement impossible d'acceder a certai - 
nes donnees inscrites dans des zones protegees 
du microcircuit sans le detruire. Par ailleurs, lors de 
I'utilisation, un protocole d'identification faisant in - 
tervenir un code personnel et secret, inscrit dans 
une zone protegee du microcircuit, permet d'in- 
terdire toute tentative d'usage de la carte si les 
conditions d'identification ne sont pas satisfaites. 

Dans le cas d'une carte bancaire, le fabricant 
de carte cree dans un premier temps des cartes 
dont le microcircuit est vierge de toute information 
personnalisee, puts dans un deuxieme temps, il y 
inscrit, par programmation des donnees secretes, 
personnalisant chaque carte. Les cartes sont en - 
suite protegees par des verrous technologiques 
irreversibles. 

Les codes personnels d'identification sont alors 
envoyes a chaque utilisateur (clients de la ban - 
que), et, par une autre route, les cartes elles- 
memes sont expediees a la banque, ou les clients 
sont pries de venir les retirer. Ce systeme se 
revele d'une grande securite contre les tentatives 
d'usurpation. 

Bien entendu, une carte a puce est susceptible 
de servir a bien d'autres applications, en dehors du 
domaine bancaire, ou I'aspect pratique de porta- 
bility de la carte et de sa securite d'utilisation 
offrent des perspectives interessantes. 

On peut penser a developper un microcircuit 
specifique de chaque cas duplication particuiier 
envisage mais il est plus economique et plus sim - 
pie de prevoir des microcircuits d'un type suffi - 
samment universel pour que Tune ou I'autre des 
applications envisagee y soit ensuite programmee. 



Dans cette perspective, des probtemes appa- 
raissent deja du point de vue de la security si on 
envisage de confier a une entite autre que le 
fabricant de microcircuit, le soin d'inscrire les 
s donnees secretes d'identification et les donnees 
fonctionnelles de sa propre application. 

En effet une personne mal intentionnee ayant 
reussi a se procurer des cartes vierges et ayant 
par ailleurs pris connaissance des techniques 
10 description d'une certaine application, serait sus- 
ceptible de recreer illicitement des cartes falsiftees 
en utilisant une technique description de donnees 
qui imite I'originale. 

Or, I'entite emettrice de ^application, qui est 
75 etrangere au fabricant de microcircuit, peut desirer 
charger elle-m§me les donnees de son applica- 
tion, entre-autres pour ne pas livrer ses secrets 
au fabricant de microcircuits. 

Ces difficultes relatives a la securite sont en- 
20 core aggravees dans le cas ou on envisage de 
creer des cartes dites "multi -application" d'un 
type universel, vierges a Torigine, et qui sont aptes 
a etre chargees successivement et dans un ordre 
de succession quelconque, de donnees et pro- 
25 grammes d'applications differents les uns des au - 
tres, par des entites emettrices qui sont etrangeres 
les unes aux autres. Le but recherche sera alors 
d'effectuer une allocation dynamique de la me- 
moire programmable dans des conditions de se - 
30 curite satisfaisantes. 

Le fabricant de microcircuits devrait pouvoir 
assurer une possibility de protection de plusieurs 
zones de memoire dont il ne connalt pas encore 
les limites individuelles, de maniere que chaque 
35 entite emettrice puisse proteger la zone ou elle a 
charge ses donnees fonctionnelles secretes, contre 
toute tentative de lecture ou d'ecriture provenant 
du deroulement d'une autre application, que ces 
tentatives proviennent d'une erreur de program - 
40 mation de I'entite ayant emis cette autre application 
ou qu'elles proviennent de la programmation illicite 
d'un fraudeur.On doit se rendre compte qu'il serait 
illusoire de confier a une pluralite d'entites sus- 
ceptibies de charger diverses applications, des 
45 secrets de programmation relatifs au chargement 
des applications en esperant que ces secrets ne 
parviennent jamais dans les mains de personnes 
mal intentionnees. Une solution ne peut etre envi - 
sagee dans cette direction d'autant plus qu'une 
50 entite bien qu'autorisee mais maladroite peut 
e me ttre une application contenant une erreur de 
programmation aboutissant a la destruction d'une 
donnee contenue dans une application etrangere a 
la sienne. 

55 L'invention vise tout particulierement le cas 

d'un microcircuit pour carte a puce du type multi - 
applications, dans lequel un haut niveau de se- 
curite est maintenu malgre que la carte soit fabri - 
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quee dans un etant vierge et qiTelle soit suscepti - 
ble d'etre chargee, dans un ordre indifferent, par 
des entites emettrices d'applications qui sont in- 
dependantes les unes des autres. En quelque 
sorte, le microcircuit souhaite devrait disposer de 
verrous mobiles mais inviolables que ce soit en 
cours de chargement, de fpnctionnement, ou par 
renvoi de signaux queiconques sur les acces 
d'entree - sortie. 

(.'invention a pour but de fournir une solution h 
ce probieme technique. 

En effet, selon ('invention, un microcircuit pour 
carte a puce, d'un type conforme au paragraphe 
introductif, est caracterise en ce que, en vue d'un 
chargement et d'une exploitation de programmes 
d'applications ind^pendants les uns des autres, te 
microcircuit est muni d'une unite centrale de mi - 
croprocesseur, d'une memoire a lecture seule 
(ROM) contenant notamment des routines fonc- 
tionnelles exclusivement executables par ('unite 
centrale et sous sa dependance, en ce que dans 
I'espace d'adressage de la memoire programmable 
sont delimitees une zone dite de repertoire et une 
zone dite des applications, lesquelles zones sont 
exclusives Tune de I'autre, en ce que la zone de 
repertoire contient une table repertoire ou les 
adresses de debut et de fin ainsi qu'un code de 
reference de chacun des programmes d'applica- 
tions susceptible d'etre charge dans une portion de 
la zone des applications, sont inscrits au fur et a 
mesure du chargement desdits programmes et en 
utilisant une desdites routines fonctionnelles, en ce 
que le circuit de controle d'adressage est agence 
pour inhiber les commandes d'ecriture et de lec - 
ture de la memoire programmable pour des 
adresses qui se situent a I'exterieur de I'intervalle 
defini par les valeurs limites de debut et de fin 
d'une application designee prealablement sur les 
acces d'entree - sortie, limites qui sont memorisees 
dans des registres verrouiltabtes, appeles registres 
de limites tandis que la voie dite d'autorisation 
prioritaire comporte des moyens pour s'affranchir 
de ('inhibition precitee en autorisant Tecriture et la 
lecture de la zone de repertoire a la condition 
exclusive que ces operations soient effectuees au 
moyen d'une desdites routines fonctionnelles du - 
rant une etape operatoire predeterminee durant 
laquelle les registres contenant les valeurs limites 
sont deverrouilles. 

Ainsi, dans le cas general ou un programme 
d'application est deja charge dans la carte et ap - 
pele par I'intermediaire les moyens d'acces 
entree - sortie, un protocole standard de recon - 
naissance de I'utilisation prevu parmi les routines 
fonctionnelles est execute. Apres quoi, une autre 
routine commande une recherche dans la table 
repertoire, les valeurs limites d'adresse corres- 
pondant au programme d'application demande, 



identifie dans ladite table par son code de refe- 
rence, et ces valeurs sont chargees dans les re- 
gistres de limites, deverrouilles durant cette etape 
initiate de fonctionnement. 

5 Le programme d'application demande est en - 

suite lance et simultanement, les registres de li- 
mites sont verrouilles de sorte que les demandes 
d'acces en ecriture ou en lecture qui designeraient 
la memoire programmable en dehors de la zone 

w d'adresses comprise entre les valeurs limites me - 
morisees, resteront sans effet, par exemple jusqu'& 
ce que le microcircuit soit mis hors tension. La voie 
d'autorisation prioritaire est en effet refermee. De 
cette manure, un programme d'application est seul 

75 a pouvoir lire ou ecrire dans la zone d'adresse qui 
lui est affectee et qui a ete fixee lors du charge- 
ment. Les autres programmes d'applications sont 
proteges contre toute tentative de lecture ou 
d'ecriture. 

20 En ce qui concerne le chargement de tout 

nouveau programme d'applications au sein de la 
carte, la securife provenant de ('absence d'interfe - 
rence avec d'autres zones de la memoire pro- 
grammable est assuree par des moyens similaires. 

25 Toute demande de chargement d'un pro- 

gramme d'application sur les moyens d'acces 
entree - sortie fait I'objet d'un protocole standard 
engage en liaison avec une routine fonctionnelle 
specialisee contenue dans la memoire a lecture 
,30 seule. Le code de reference de ('application ainsi 
que I'espace memoire requis doivent etre annon - 
ces durant ce protocole. Une routine fonctionnelle 
specifique a pour effet de rechercher dans la table 
repertoire quelle est la premiere adresse disponible 

35 dans la zone des applications (I'adresse qui suit 
1'adresse de fin la plus elevee des programmes 
d'applications deja charges ou la premiere adresse 
de la zone des applications lorsque la carte est 
vierge). L'adresse de fin de I'application demandee 

40 est calculee a partir de la demande d'espace me - 
moire annoncee precedemment. Lorsque cette 
adresse de fin d'application est compatible avec 
I'espace memoire de la zone des applications, les 
valeurs limites d'adresses de debut et de fin ainsi 

45 que le code de reference de I'application sont alors 
inscrits dans la table repertoire et ces valeurs li- 
mites sont chargees dans les registres de limites, 
toujours par le moyen d'une routine fonctionnelle 
preetablte et intangible. 

so Durant ces etapes qui precedent le charge- 

ment, les registres de limites sont deverrouilles, et 
ils peuvent le rester durant le chargement du pro- 
gramme d'application qui s'ensuit. La securite re - 
cherchee est neanmoins conservee par le fait que 

55 le chargement du programme d'application est ef- 
fectue sous le controle de ('unite centrale et par 
I'effet d'une routine fonctionnelle preetablie et sOre 
qui exclut toute modification de contenu des re- 
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gistres de limites. 

On peut aussi prevoir un verrouillage de ces 
registres qui soit commande par programmation 
juste avant ie chargement. 

Toute tentative de chargement en dehors des 
limites d'adresses etablies precedemment restera 
sans effet. L'operation de chargement peut etre 
completee, si on le juge necessaire, par une routi - 
ne de verification des donnees charges, une ve - 
rification de signature, un test de parity... etc... mais 
de telles operations n'auront pas pour effet d*ac - 
croftre de maniere significative la securite de 
fonctionnement du microcircuit selon i'invention. 

La voie d'autorisation prioritaire peut etre 
commands de differentes manieres en appliquant 
des conditions logiques appropri^es et en fonction 
du deroulement des etapes operatoires qui suivent 
la mise sous tension du microcircuit. 

Toutefois, selon un mode de mise en oeuvre 
prefere de I'invention, qui offre toute garantie du 
point de vue de la securite, le microcircuit se 
caracterise en ce qu'il comporte une bascule bis - 
table, placee dans un premier etat exclusivement 
lors d'une mise sous tension du microcircuit, puis 
placee dans un deuxieme etat oppose au premier, 
des qu'un compteur ordinal assocte a I'unite cen- 
trale, contient une valeur d'adresse comprise dans 
I'espace d'adressage de la memoire programma- 
ble, et en ce que cette bascule bistable delivre un 
signal de verrouillage/deverrouillage pour la com- 
mande de verrouillage des registres de limites et 
pour la commande de la voie d'autorisation priori - 
taire. 

Du fait qu'il est lie au compteur ordinal, le 
signal de verrouillage/deverrouillage fournit un 
moyen inviolable par un programme duplication 
quelconque pour le verrouillage des registres de 
limites et de la voie d'autorisation prioritaire, bien 
que la bascule bistable reste par sa nature un 
element reversible dans le temps. 

Comme les routines fonctionnelles qui ont pour 
objet de lire et/ou ecrire dans la table repertoire 
sont inscrites dans la memoire a lecture seule, le 
compteur ordinal pointe cette memoire pour les 
executer pas a pas. 

II suffit done de placer ['execution de ces rou - 
tines dans des etapes operatoires qui precedent 
toute execution de programme inscrit dans la me - 
moire programmable. La voie d'autorisation priori - 
taire est encore ouverte tant qu'il s'agit de routines 
executees sous le contrdle de I'unite centrale. Des 
que le compteur ordinal sera charge d'une adresse 
designant la memoire programmable, le signal de 
verrouillage/deverrouillage sera aussitot place dans 
son etat realisant le blocage, verrouillant les regis- 
tres de limites et interdisant I'acces a la table 
repertoire. 



En pratique ceci peut avantageusement etre 
realise dans un microcircuit caracterise en ce que 
le circuit de contrdle d'adressage comporte une 
porte OU dite de validation, dont la sortie com- 
5 mande la transmission des signaux d'ecriture et de 
lecture de la memoire programmable, en ce qu'une 
premiere entree de cette porte de validation regoit 
un signal resultant de la comparaison de toute 
adresse appelee avec le contenu des registre de 
jo limites, et une autre entree par laquelle s'effectue 
I'autorisation prioritaire, regoit un signal resultant 
du produit logique entre le signal de 
verrouillage/deverrouillage et le signal de sortie 
d'un decodeur d'adresses reconnaissant les seules 
75 adresses de la zone de repertoire. 

Jusqu'& present on a consid6r6 que I'espace 
d'adressage de la memoire programmable etait 
protege dans les conditions precitees relatives h la 
zone de repertoire et la zone des applications. 
20 II peut cependant etre utile de prevoir en outre 

une certaine zone de I'espace d'adressage de la 
memoire programmable qui soit librement acces- 
sible par tout programme d'application, par exem- 
ple pour y placer provisoirement des resultats de 
25 traitement ou pour transmettre des donnees d'une 
application a une autre. 

Sans amoindrir la securite, cette facilite peut 
etre obtenue aisement par une legere modification 
du circuit de controle d'adressage precedemment 
30 defini. Selon ce mode de mise en oeuvre, un 
microcircuit selon I'invention est caracterise en ce 
qu'une zone dite "publique" est en outre prevue 
dans I'espace d'adressage de la memoire pro- 
grammable, zone qui est distincte de la zone de 
35 repertoire et de la zone des applications, et en ce 
que le circuit de controle d'adressage comporte un 
decodeur d'adresse supplemental, reconnaissant 
les seules adresses de la zone publique, qui deli - 
vre en sortie un signal applique a une entree 
40 supplemental de la porte OU de validation. 

La description qui va suivre en regard des 
dessins annexes, donnes a titre d'exempies non 
limitatifs, fera bien comprendre en quoi consiste 
I'invention et comment elle peut etre realisee. 
45 La figure 1 represente un schema de principe 
d'un microcircuit selon I'invention, 
la figure 2 est un schema -bloc d'une portion 
du microcircuit delivrant un signal de 
verrouillage/deverrouillage et, 
so la figure 3 illustre schematiquement I'organisa- 
tion d'une zone particuliere de la memoire pro- 
grammable. 

La figure 1 represente le schema general et 
simplifie d'un microcircuit selon I'invention. 
55 Sur cette figure, et pour plus de clarete, les 

elements qui ne concernent pas directement Tin - 
vention n'ont pas ete represents. Le microcircuit 
comporte une unite centrale 10 de microproces- 
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seur, une me§moire vive 1 1 , une memoire a lecture 
seule 12, une memoire programmable 13 par 
exemple une EEPROM ainsi qu'un circuit de 
controle d'adressage 14 de la memoire program- 
mable 13. Les elements prgcites sont relies entre 
eux par un systeme de bus 15 vehiculant les 
adresses et les donnees entre ces differents ele - 
ments. Pour plus simplicite le systeme de bus 15 a 
ete represents par une liaison unique bien qu'on 
puisse, selon les cas, utiliser un bus d'adresses et 
un bus de donnees qui soit separes Tun de I'autre. 
Comme cela est de pratique courante, le systeme 
de bus 15 peut encore etre un bus unique sur 
lequel les adresses et les donnees sont multi - 
plexees temporellement. A I'unite centrale 10 sont 
associes des moyens d'acces entree - sortie 16, 
moyens qui sont isoles du systeme de bus 15 de 
maniere a garantir un acces controle par I'unite 
centrale 10 aux zones sensibles du microcircuit 
contenant des donnees a proteger. 

Le circuit de controle d'adressage 14 regoit de 
I'unite centrale 10 un ensemble de liaisons de 
commande 20 parmi lesqueltes figurent essentiel - 
lement les commandes d'ecriture W de lecture R 
et d'effacement E lorsqu'elies sont destinees a la 
memoire programmable 13. 

Les commandes de lecture et d'ecriture pour la 
memoire vive 1 1 et les commandes de lecture 
pour la memoire a lecture seule 12, n'ont pas ete 
representees, pour plus de clarte de la figure et du 
fait qu'elles n'interferent pas avec I'invention. Les 
commandes W, R et E destinees a la memoire 
programmable 13 peuvent etre inhibees ou vali - 
dees par le circuit de controle d'adressage 14 dans 
des conditions qui seront expliquees ci-apres. 
Conformement a une pratique en usage dans les 
microcontroleurs, la memoire a lecture seule 12 et 
la memoire programmable 13 font partie d'un 
meme systeme d'adressage tandis que la memoire 
vive 1 1 est adressee de maniere distincte et ex - 
elusive de Tadressage des memoires 12 et 13. 
Dans Tespace d'adressage de la memoire pro- 
grammable 13 sont delimitees une zone de reper- 
toire ZR et une zone des applications ZA, zones 
qui sont exclusives Tune de I'autre et qui sont 
definies une fois pour toutes par construction. 

Initialement les zones ZR et ZA sont vierges. 
Le microcircuit peut etre charge de programmes 
duplications independant les uns des autres dans 
un ordre et a des moments qui sont indifferents. 
Au fur et a mesure du chargement desdits pro- 
grammes ceux-ci vont etre inscrits successive - 

ment dans des zones distinctes ZAi , ...ZA ZA n 

qui sont adjacentes et qui remplissent progress) - 
vement la zone des applications ZA. 

Bien entendu, chaque zone ZA* d'une applica - 
tion determinee peut egalement contenir des don - 
nees (autres que des codes operatoires) qui sont 



propres a cette application et/ou des emplace- 
ments memoire destines a recevoir des resultats 
de traitement. Selon ('invention la zone de reper- 
toire ZR contient une table repertoire ou les 

5 adresses de debut et de fin ainsi qu'un code de 
reference de chacun des programmes d'applica- 
tions charges dans la zone des applications sont 
inscrits lors du chargement desdits programmes. 
Ainsi, un t §me programme d'application charge dans 

w la zone ZA { entre les adresses ZAi, et ZA ih respe- 
ctivement de debut et de fin du programme d'ap - 
plication i a ete charge au cours d'un protocole au 
cours duquel les adresses ZA i( et ZA ih ont ete 
prealablement d^terminees et charg^es dans la 

;s table repertoire de la zone de repertoire ZR ac- 
compagnes d'un code reference du programme 
d'application i. Le protocole de chargement qui 
vient d'§tre mentionne utilise une desdites routines 
foncttonnelles inscrites de maniere immuable dans 

20 la memoire a lecture seule 12. 

Le circuit de controle d'adressage 14 est 
agence pour inhiber les commandes de lecture (R) 
d'ecriture (W) et d'effacement (E) destinees a la 
memoire programmable 13 pour des adresses qui 

25 se situent a Texterieur de I'intervalle defini par les 
valeurs limites de debut ZA M et de fin ZA jh d'une 
application ZAj designee prealablement sur les 
acces d'entree/sortie 16. Pour ce fatre, le systeme 
de bus 15 est partage des Tentree dans le circuit 

30 de controle d'adressage 14 en un bus de donnees 

21 et un bus d'adresses 22. Le bus de donnees 21 
est applique en parallele sur deux registres ver - 
rouiliables dits registres de limites 25, 26 respec- 
tivement, ou les adresses de debut et de fin d'une 

35 application en cours de traitement peuvent etre 
memorisees et verrouillees au moyen d'un signal 
de verrouillage/deverrouillage (LOC) provenant 
d'une borne 60. Le bus d'adresses 22, interne au 
circuit de controle d'adressage 14, est applique en 

40 parallele a deux comparateurs 28, 29 respective - 
ment associes aux registres de limites 25 et 26. Le 
comparateur 28 delivre un signal d'autorisation 
lorsque Tadresse courante sur le bus d'adresses 

22 est superieure ou egale a Tadresse de debut 
45 memorisee dans le registre de limites 25 tandis 

que le comparateur 29 delivre un deuxieme signal 
d'autorisation lorsque Tadresse courante sur le bus 
d'adresse 22 est inferieure ou egale a Tadresse 
limite de fin d'application memorisee dans le re- 

50 gistre 26. Les deux signaux d'autorisation delivres 
en sortie des comparateurs 28 et 29 sont appliques 
aux deux entrees d'une porte ET 30 dont la sortie 
31 presente un signal d'autorisation lorsque 
Tadresse courante presentee sur le bus d'adresse 

55 22 est comprise dans les limites des adresses 
memorisees dans les registres 25 et 26. Le signal 
d'autorisation present a la sortie 31 de la porte 30 
est applique via une porte OU 32, dite de valida- 
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tion, a Tune des entrees de trois portes ET 35, 36, 
37 dont ('autre entree de chacune d'elle regoit 
respectivement les commandes de lecture (R) 
ecriture (W) et d'effacement (E). Ces commandes 
ne sont done transmises a la memoire program - 
mable 13 que lorsque les portes ET 35, 36, 37 sont 
passantes e'est-a-dire lorsque I'adresse cou- 
rante presente sur le bus d'adresses 22 est com - 
prise ou egale aux limites d'adresses memorises 
dans les registres 25 et 26 et au contraire ces 
commandes sont inhibees dans le cas ou I'adresse 
courante est ext§rieure h ces valeurs limites. 

La porte OU 32 constitue une partie de ce qui 
a et£ appele precedemment voie d'autorisation 
prioritaire, du fait qu'elle comporte une deuxieme 
entree 40 sur laquelle est applique un signal d'au- 
torisation durant une Stape operatoire predetermi - 
nee qui suit toute mise sous tension du microcir- 
cuit. 

Pour reaiiser ladite voie d'autorisation priori- 
taire, le signal de verrouillage/deverrouillage 
(LOC) est inverse par un inverseur 41 et appliqu£ a 
une des deux entrees d'une porte ET 42. Sur 
I'autre entree de cette porte ET 42 est applique le 
signal de sortie d'un decodeur d T adresses 43 re- 
connaissant les seules adresses de la zone de 
repertoire (ZR) et fournissant a la porte ET 42 un 
signal d'autorisation lorsque I'adresse courante 
presentee sur le bus d'adresses 22 est comprise 
dans I'espace d'adressage de la zone de repertoire 
(ZR). La porte ET 42 effectue ainsi le produit 
logique entre le signal de 

verrouillage/deverrouillage (LOC) et le signal de 
sortie du decodeur d'adresses 43 pour fournir un 
signal d'autorisation prioritaire a I'entree 40 de la 
porte de validation 32. Le decodeur d'adresses 43 
qui reconnait uniquement des adresses de la zone 
de repertoire (ZR) de la memoire programmable 13 
peut etre d'un type tres simple lorsque le nombre 
d'octets de la zone de repertoire (ZR) peut s'ex - 
primer par une puissance entiere de deux telle 
qu'une valeur de 256 octets ou 512 octets etc. A 
titre d'exemple, la zone de repertoire peut avoir 
une adresse de debut exprimee en hexadecimal 
par la valeur 8000 et I'adresse de fin de cette zone 
par I'adresse hexadecimale 80FF. 

Le microcircuit represents a la figure 1 com - 
porte encore une disposition optionnelle selon la- 
quelle une zone dite "publique" ZB est prevue 
dans I'espace d'adressage de la memoire pro- 
grammable 13, zone qui est distincte de la zone de 
repertoire ZR et de la zone des applications ZA et 
que Ton a fait figurer a titre d'exemple entre les 
zones ZR et ZA et adjacente a celles-ci. Du fait 
que Ton a prevu un acces inconditionnel a cette 
zone publique ZP, la porte de validation 32 com - 
porte une troisieme entree 50 par laquelle est 
applique un signal de validation provenant d'un 



decodeur d'adresses 51 similaire au decodeur 
d'adresses 43 a I'exception pres qu'il ne reconnait 
que les seules adresses de la zone publique ZP de 
la memoire programmable 13. 
5 Ainsi que cela a deja ete mentionn£, le signal 

de verrouillage/deverrouillage (LOC) est place dans 
un etat de d§verrouillage (LOC = 0) durant une 
etape operatoire predetermine qui suit toute mise 
sous tension du microcircuit. II peut etre genere 
w par tous systemes logiques convenables permet- 
tant d'autoriser le chargement des registres de 
limites 25 et 26 et de debloquer la porte ET 42 
pour permettre la lecture et/ou I'ecriture de la table 
repertoire situee dans la zone de repertoires ZR. 
75 Selon un mode de mise en oeuvre de ('inven- 

tion particulierement avantageux pour la securite 
elevee qu'il procure, le signal de 
verrouillage/deverrouillage (LOC) est produit en 
liaison avec le contenu d'un compteur ordinal tel 
20 qu'il est generatement connu et associe a une 
unite centrale de microprocesseur. 

On se reporte maintenant h la figure 2 pour la 
description de cette portion du microcircuit. 

Sur cette figure, on a represents un compteur 
25 ordinal 55 qui fait partie de I'unite centrale 10 et 
qui permet I'execution pas a pas de routines 
fonctionnelles contenues dans la memoire a lecture 
seule 12. Cette disposition est par ailleurs classi - 
que dans tous les microcontroleurs ou micropro- 
30 cesseurs et ne necessite pas, de ce fait, une 
description detaillee. Le compteur ordinal 55 est 
relie a un decodeur 56, 57 qui actionne a sa sortie, 
via une porte OU 66 une bascule bistable 58, par 
exemple de type RS, lorsque le contenu du 
35 compteur ordinal 55 depasse une certaine valeur 
d'adresse qui dans I'exemple illustre a pour limite 
la valeur hexadecimale 7FFF. Cette limite 
d'adresse correspond au cas ou la memoire pro- 
grammable a son adresse la plus basse exprimee 
40 en hexadecimal par la valeur 8000. Une routine 
fonctionnelle, par ailleurs classique en matiere de 
microcontroleur, effectue la remise a zero d'un 
certain nombre de registre et dans le cas precis, 
applique un signal de remise a zero de la bascule 
45 bistable 58 sur son entree de remise a zero 59. La 
bascule bistable 58 delivre en definitive le signal 
de verrouillage/deverrouillage (LOC) sur la borne 
60 representee egalement a la figure 1, a I'entree 
du circuit de controte d'adressage 14. 
50 A la suite d'une mise sous tension du micro - 

circuit, et tant que I'unite centrale 10 execute les 
routines fonctionnelles contenues dans la memoire 
a lecture seule 12, le compteur ordinal 55 designe 
des adresses de programme qui sont relatives a 
55 cette meme memoire a lecture seule et la bascule 
bistable 58 delivre un signal de deverrouillage 
(LOC = 0). La table de repertoire peut etre lue ou 
ecrite sous le controle de I'unite centrale 10 et les 
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registres de limites 25, 26 peuvent etre charges 
par cette meme unite centrale. Au contraire, des 
lors qLTun programme d'application est appel£ (de 
sorte que I'adresse contenue dans le compteur 
ordinal 55 depasse necessairement I'adresse 
hexadecimale 7FFF, donnee comme limite dans 
I'exemple) la bascule bistable 58 est plac^e dans 
I'etat opposd au premier 6tat et delivre un signal 
de verrouillage sur la borne 60 (LOC = 1). Les 
registres de limites 25 et 26 ainsi que la voie 
d'autorisation prioritaire seront desormais verrouil - 
les jusqu'a la prochaine mise hors tension du mi - 
crocircuit. Comme on le voit cette disposition offre 
toute securite pour garantir une absence d'interfe - 
rence entre les differents programmes duplica- 
tions susceptibles d'etre charges dans la zone des 
applications ZA. 

La porte OU 66 permet egalement une variante 
de fonctionnement selon laquelle le signal de ver - 
rouillage (LOC = 1) peut etre produit par une 
routine specifique contenue dans la memoire ROM 
12, et done meme si le contenu du compteur n'a 
pas encore depasse la valeur limite de 7FFF. La 
routine fonctionnelle prevue a cet effet impose a 
I'unite centrale 10 d'emettre un signal de com- 
mando sur une liaison 67 qui est appfiquee a une 
deuxieme entree de la porte OU 66. On peut done 
ainsi emettre un signal de verrouillage par pro- 
grammation qui subsistera jusqu'Si la prochaine 
remise a zero. Cette disposition permet d'accroltre 
encore la securite pendant le chargement d'un 
nouveau programme d'application et pendant 
('execution d'une application qui ne ferait appel 
qu'a des routines contenues dans la memoire ROM 
12 et dont la zone ZAj reservee dans la memoire 
programmable ne contiendrait que des donnees (et 
aucun code operatoire). 

A I'aide de la figure 3, on va expliquer succin - 
tement comment la zone de repertoire ZR de la 
memoire programmable 13 peut etre organisee. La 
figure 3 se refere par ailieurs a un exempte dont 
les valeurs sont purement arbitrages et n'ont pas 
d'autre but que de rendre les explications plus 
claires. 

On suppose que la zone repertoire de la me - 
moire programmable 13 commence a I'adresse 
hexadecimale 8000 et finit a I'adresse 80FF. Dans 
cette zone d'un volume de 256 octets, on peut 
prevoir, si on le desire, une portion designee par 
ZID destinee a recevoir des donnees d'identifica - 
tion de la carte, du proprietaire de cefle-ci et des 
cles. En dehors de la zone d'identification ZID se 
situe la table de repertoire TR proprement dite qui 
debute a I'adresse INI et s'etend jusqu'a I'adresse 
hexadecimale 80FF. Comme indique sur la figure, 
la table repertoire TR contient les inscriptions 
successives d'un premier programme charge, dont 
le code de reference est appele "PR-APP-A", 



d'une longueur de 350 octets, dont I'adresse 
hexadecimale de debut d'execution de programme 
est egale a 8200 ainsi que I'adresse de d6but de 
zone, et I'adresse de fin de zone 6gale a 835D, 

5 puis un programme reference "PR-APP-B" 
d'une longueur de 250 octets, ayant pour adresse 
de d£but d'execution de programme la valeur 
hexadecimale 8365, pour I'adresse de debut de 
zone, 835E pour I'adresse de fin 8457, et enfin un 

w programme reference "PR-APP-C, d'une lon- 
gueur de 180 octets, ayant pour adresse de debut 
d'execution de programme la valeur hexadecimale 
8460 pour I'adresse de debut de zone, 8458 et 
pour adresse de fin la valeur 850C. En effet, les 

/5 adresses de debut d'execution de programme, 
comme I'indique cet exemple, ne coincident pas 
necessairement avec I'adresse de d£but de zone 
allouee au meme programme, mais elles sont ne - 
cessairement comprises dans ladite zone allouee. 

20 On va decrire tout d'abord le cas ou un pro - 

gramme d'application de\h charge dans la carte est 
appele sur les moyens d'acces d'entree/sortie. 

Toute demande d'execution d'un programme 
d'application fait i'objet d'une procedure qui peut 

25 se decomposer en 5 etapes principales : 

- une etape d'initialisation qui peut inclure une 
procedure d'identification de la carte et son 
utilisateur, 

- une procedure de demande de I'application 
30 annoncee sur les moyens d'entree - sortie, 

- une procedure de recherche dans la table de 
repertoire TR pour determiner si I'application 
demandee existe, et dans I'affirmative, le 
chargement des donnees specifiques de 

35 I'application prelevees dans cette table, 

- le chargement des registres de limites, 

- et enfin ('execution proprement dite du pro - 
gramme d'application demande. 

Des la mise sous tension du microcircuit, la bas- 
40 cule bistable 58 est remise a zero en meme temps 
qu'un certain nombre de registres et notamment le 
compteur ordinal 55. Apres un eventuel protocole 
de reconnaissance mettant en jeu des donnees 
d'identification contenues dans la portion d'identi - 
45 fication ZID de la zone repertoire ZR, un pro- 
gramme d'application par exemple celui reference 
"PR - APP - B" est appele. 

Sous I'effet d'une routine preetablie, ('unite centrale 
10 effectue une recherche dans la table repertoire 
' so TR de maniere a determiner si un tel programme 
d'application est present. Dans I'affirmative les va - 
leurs d'adresse de debut et de fin de ce program - 
me d'application, dans I'exemple les adresses 
hexadecimales 835E et 8457 respectivement, sont 
55 prelevees dans la table de repertoire TR et toujours 
sous I'effet d'une routine preetablie ces valeurs 
limites sont chargees dans les registres des limites 
25 et 26 respectivement. Jusqu'a present le fonc - 



7 



13 



EP 0 540 095 A1 



14 



tionnement du microcircuit n'a fait appel qu'a des 
routines situees dans la memoire a lecture seule 
12 de sorte que le compteur ordinal n'a jamais 
franchi la limite des adresses designant la memoire 
programmable 13 soit dans notre exemple une 
adresse superieure a la valeur hexadecimale 7FFF. 
Dans I'etape operatoire qui suit et qui consiste a 
ex£cuter le programme appele, le compteur ordinal 
55 est charge avec I'adresse de debut d'execution 
du programme duplication appel§, par exemple 
I'adresse hexadeciame 8365. Cect entraTne un 
changement d'etat de la bascule bistable 58 et 
procure sur la borne 60 un signal de verrouillage 
(LOC = 1). Ce signal a pour effet de verrouiller les 
registres de timites 25 et 26 et de bloquer la voie 
d'autorisation prioritaire formee par la branche 
comportant I'inverseur 41, la porte ET 42 et I'en - 
tree 40 de la porte de validation 32. Desormais les 
operations d'ecriture, de lecture et d'effacement de 
la memoire programmable ne peuvent plus etre 
executees que dans la seule portion comprise dans 
les limites de d^but et de fin du programme appele 
ou dans la zone publique ZP. Cet acces selectif va 
persister jusqu'a la mise hors tension du microcir- 
cuit. Les operations d'ecriture et de lecture dans la 
zone dite publique ZP restent possibles au moyen 
du signal d'autorisation present sur I'entree 50 de 
la porte de validation 32 et provenant du decodeur 
d'adresse 51 qui reconnait les adresses corres- 
pondant a cette zone ZP. 

On en vient maintenant a decrire le fonction - 
nement du microcircuit dans le cas ou un pro- 
gramme d'application doit etre charge dans la 
memoire programmable 13. Des la mise sous ten- 
sion du microcircuit, une etape d'initialisation est 
engagee qui est essenttellement similaire a ceile 
deja mentionnee pour ('execution d'un programme 
d'application. Dans une seconde etape, et sous le 
controle d'une routine fonctionnelle preetablie, le 
code de reference du programme a charger est 
annonce sur les entrees - sorties ainsi que le vo - 
lume de memoire necessaire a ce programme ex - 
prime par exemple en nombre d'octets. Dans une 
troisieme etape operatoire, et egalement sous I'ef - 
fet d'une routine fonctionnelle preetablie, une re- 
cherche est effectuee dans la table repertoire TR 
contenue dans la zone de repertoire ZR de ma- 
niere a determiner si le programme demande a 
deja ete charge et sinon quelle est la derniere 
adresse limite de fin de programme inscrite dans la 
table. Cette adresse correspond egalement a 
I'adresse occupee la plus elevee de la zone ZA 
puisque les programmes ont ete charges succes - 
sivement a des adresses croissantes. Dans 
I'exemple il s'agit de la valeur hexadecimale 850C. 
La meme routine fonctionnelle determine d'une 
part la valeur d'adresse qui suit immediatement 
c'est-a-dire I'adresse hexadecimale 850D qui 



sera prevue comme valeur limite de debut du 
nouveau programme a charger et calcule d'autre 
part quelle sera I'adresse de fin de programme a 
charger compte tenu du volume de memoire an- 
5 nonce dans la seconde etape. Dans une quatri&me 
etape, I'unite centrale effectue un test pour deter - 
miner si I'adresse de fin de programme ainsi cal - 
culee est compatible avec I'adresse la plus Elevee 
de la zone des applications ZA, puis sous I'effet 
w d'une routine preetablie, les valeurs limites de de - 
but et de fin de programme ainsi d6termin6es sont 
chargees dans les registres de limites 25 et 26. Du 
fait que jusqu'a present I'unite centrale a effectue 
des routines fonctionnelles situees dans la me - 
15 moire a lecture seule 12, le compteur ordinal n'a 
jamais franchi la limite des valeurs d'adresse qui 
concernent la memoire programmable 13. Ainsi le 
signal de verrouillage/d£verrouillage est dans son 
etat de d^verrouillage (LOC = 0) ce qui a permis 
20 le chargement des registres des limites 25 et 26 
ainsi que la lecture de la table de repertoire au 
moyen de la voie d'autorisation prioritaire 41 , 42 et 
32, Dans une cinquieme etape et sous I'effet d'une 
routine fonctionnelle, I'unite centrale 10 complete la 
25 table repertoire de la zone de repertoire ZR en 
inscrivant a la suite des references deja presentes, 
le code de reference, les valeurs limites d'adresses 
de debut et de fin precedemment determinees et 
qui concernent le programme d'application en voie 
30 de chargement, ainsi que I'adresse de debut 
d'execution de ce programme. 

Une sixieme etape operatoire, qui suit, 
concerne essentiellement le chargement dudit 
programme, chargement qui ne peut etre accompli 
35 qu'& I'interieur des limites fixees par les valeurs 
d'adresses de debut et de fin memorisees dans les 
registres des limites 25 et 26. Pendant ce charge - 
ment les registres de limites 25 et 26 peuvent ne 
pas etre verrouilles (LOC = 0) mais lesdits regis - 
40 tres effectuent le controle des operations d'ecriture 
de la meme maniere que s'ils avaient ete verrouil - 
les. La securite est neanmoins maintenue du fait 
que le chargement est execute sous le controle de 
I'unite centrale 10 par I'effet d'une routine fonc- 
45 tionnelle qui ne peut etre modifiee par un utilisa- 
teur. Toutefois, il est egalement possible d'activer 
la bascule 58 par programmation au moyen d'un 
signal transmis par la liaison 67 a la porte OU 66. 
Dans ce cas les registres de limites peuvent etre 
50 verrouilles lors du chargement. Toute tentative de 
chargement d'un programme d'application d'une 
longueur superieure au volume de memoire an- 
nonce restera inefficace par I'effet du controle 
exerce par les registres de limites 25 et 26 et de la 
55 porte ET 30. 

Si on le desire Tetape de chargement du pro- 
gramme peut etre suivie par une verification des 
donnees chargees, une verification de signature 
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finale, un test de parite, et.... II est aise de detecter 
une tentative de chargement d'un programme de 
longueur superieure a la longueur annoncee du fait 
que la ou les dernieres donnees presentees au 
chargement ne sont pas en fait enregistrees dans 
la memoire programmable de sorte qu'une v^rifi - 
cation de ces donnees finales revele la tentative 
d'un chargement abusif qu'il soit accidentel ou 
frauduleux. 

En se referant a nouveau a la figure 1, un 
dispositif additionnel pour la signalisation d'une 
anomalie de fonctionnement va maintenant etre 
decrit. Ce dispositif additionnel comporte une porte 
ET 62 a deux entrees, une porte OU 63 a 3 
entrees et un inverseur 64. 

L'inverseur 64 regoit en entree le signal de 
sortie de la porte de validation 32, et le transmet 
apres inversion, a une entree de la porte ET 62, 

La porte OU 63 a sa sortie connectee a I'autre 
entree de la porte ET 62 et regoit en entree les 
trois signaux de commande R, W, E destines a la 
memoire programmable 13, en formant ainsi la 
somme logique de ces signaux de commande. 

Lorsque Tune de ces operations est demandee, 
ie signal en sortie de ia porte OU 63 est a Peta't 
haut. Simultanement, si aucune des conditions 
d'autorisation n'est realisee, ce qui produit un si - 
gnai a I'etat bas en sortie de la porte OU 32, la 
porte ET 62 est alors activee et produit en sortie 
un signal renvoye a I'unite centrale 10, par exem - 
pie un signal d'interruption (INT = 1). 

Ainsi, dans le cas d'utilisation d'une interrup- 
tion, une anomalie de fonctionnement et plus par- 
ticulierement une demande non autorisee d'acces 
a la memoire programmable 13 aboutira a une 
interruption de fonctionnement du microcircuit 
(interruption non masquable) et on peut, si on le 
desire, produire un message d'avertissement sur te 
terminal d'exploitation de la carte. 

Le signal INT qui est produit en cas d'anomalie 
peut §tre utilise pour operer toute modification 
desirable du fonctionnement du microcircuit : par 
exemple invalider le programme qui a produit 
I'anomalie, voire invalider totalement le fonction - 
nement de la carte. 

Une consequence avantageuse de I'invention 
est que seules les routines fonctionneltes incrites 
dans la memoire a lecture seule devront etre ex - 
tensivement testees et approuvees alors que les 
programmes duplications pourront §tre crees par 
diverses entites, sous leur propre responsabilite, et 
sans risque d* interference indue entre les applica - 
tions. 

Le microcircuit selon Tinvention offre done une 
parfaite securite pour une utilisation de carte a 
puce multi - applications. 



Revendications 

1. Microcircuit pour carte a puce comprenant 
entre -autres : des moyens d'accfes entree - 

5 sortie, au moins une memoire qui est pro- 

grammable et accessible par un espace 
d'adressage a adresses cons§cutives, un cir- 
cuit de contrdle d'adressage de cette memoire 
programmable determinant soit une inhibition, 

io soit une validation des commandos d'^criture 

et/ou de lecture par la comparaison de 
Padresse demandee avec deux valeurs limites 
de debut et de fin d'une zone particuliere 
d'adresses, limites qui sont memorises au 

75 sein du circuit de controle d'adressage tequel 

circuit comporte egalement une voie d'autori - 
sation prioritaire permettant de s'affranchir 
temporairement de ladite inhibition dans des 
circonstances predetermines et particulieres, 

20 caracterise en ce que, en vue d'un chargement 

et d'une exploitation de programmes d'appli - 
cations independants les uns des autres, le 
microcircuit est muni d'une unite centrale de 
microprocesseur, d'une memoire a lecture 

25 seule (ROM) contenant notamment des routi - 

nes fonctionnelles exclusivement executables 
par I'unite centrale et sous sa dependance, en 
ce que dans I'espace d'adressage de la me - 
moire programmable sont delimitees une zone 

30 dite de repertoire et une zone dite des appli - 

cations, lesquelles zones sont exclusives Tune 
de I'autre, en ce que la zone de repertoire 
contient une table repertoire ou les adresses 
de debut et de fin ainsi qu'un code de refe- 

35 rence de chacun des programmes duplica- 

tions susceptible d'etre charge dans une por - 
tion de ia zone des applications, sont inscrits 
au fur et a mesure du chargement desdits 
programmes et en utilisant une desdites rou- 

40 tines fonctionnelles, en ce que le circuit de 

controle d'adressage est agence pour inhiber 
les commandes d'ecriture et de lecture de la 
memoire programmable pour des adresses qui 
se situent a I'exterieur de i'intervalle defini par 

45 les valeurs limites de debut et de fin d'une 

application designee prealablement sur les 
acces d ' entre e - sortie, limites qui sont me- 
morisees dans des registres verrouillables, 
appeles registres de limites, tandis que la voie 

so dite d'autorisation prioritaire comporte des 

moyens pour s'affranchir de I'inhibition preci - 
tee en autorisant I'ecriture et la lecture de la 
zone de repertoire a la condition exclusive que 
ces operations soient effectuees au moyen 

55 d'une desdites routines fonctionnelles durant 

une etape operatoire predeterminee durant 
laquelle les registres contenant les valeurs li - 
mites sont deverrouilles. 
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Microcircuit selon la revendication 1, caracte- lecture, d'ecriture et d'effacement, a la sortie 

r\s6 en ce qu'il comporte une bascule bistable, d'une porte OU additionnelle. 

placee dans un premier etat exctusivement iors 

d'une mise sous tension du microcircuit, puis 

placee dans un deuxteme 6tat oppose au 5 

premier dds qu'un compteur ordinal associe a 

I'unite centraie, contient une valeur d'adresse 

comprise dans Tespace d'adressage de la 

memoire programmable, et en ce que cette 

bascule bistable deiivre un signal de w 

verrouillage/d^verrouillage pour la commande 

de verrouillage des registres de limites et pour 

la commande de la voie d'autorisation priori - 

taire. 

Microcircuit selon la revendication 2, caracte- 
rise en ce que ladite bascule bistable peut 
egalement etre placee dans ledit deuxieme 
etat par un signal de commande delivr£ par 
('unite centraie sous I'effet d'une routine tone 20 
tionnelle prevue a cet effet. 



4. Microcircuit selon Tune des revendications 1 a 
3, caracterise en ce que te circuit de controle 
d'adressage comporte une porte OU dite de 25 
validation, dont la sortie commande la tran - 
smission des signaux d'ecriture et de lecture 

de la memoire programmable, en ce qu'une 
premiere entree de cette porte de validation 
regoit un signal resultant de la comparaison de 30 
toute adresse appelee avec ie contenu des 
registres de limites, et une autre entree par 
laquelle s'effectue I'autorisation prioritaire, re- 
goit un signal resultant du produit logique entre 
le signal de verrouitlage/deverrouillage et le 35 
signal de sortie d'un decodeur d'adresses re - 
connaissant les seules adresses de la zone de 
repertoire. 

5. Microcircuit selon la revendication 4, caracte - 40 
rise en ce qu'une zone dite "publique" est en 
outre prevue dans Tespace d'adressage de la 
memoire programmable, zone qui est distincte 

de la zone de repertoire et de la zone des 
application, et en ce que te circuit de controle 45 
d'adressage comporte un decodeur d'adresse 
supplementaire reconnaissant les seules 
adresses de la zone publique, qui deiivre en 
sortie un signal applique a une entree sup- 
plementaire de la porte OU de validation. so 

6. Microcircuit selon I'une des revendications 4 
ou 5, caracterise en ce qu'un signal de de - 
tection d'anomalie (INT) est produit en sortie 
d'une porte ET additionnelle dont une pre- 55 
miere entree regoit le signal issu de la porte 

de validation, et une deuxieme entree regoit la 
somme logique des signaux de commande de 
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